<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>具名槽口</title>
    <script src="js/vue.js"></script>
    <!-- 
        具名槽口：
            使用slot占位，在slot标签内，增加name属性给槽口定义一个名称
            在调用的时候使用v-slot:槽口 或者 #槽口名称
     -->
</head>
<body>

    <div id="box">
        <myslot>
            <template slot="header">
                旧写法：具名槽口
            </template>
        </myslot>
        <myslot>
            <template v-slot:header>
                新写法：具名槽口 header
            </template>
            <template #footer>
                新写法：具名槽口 footer
            </template>
        </myslot>
    </div>
    <template id="myslot">
        <div>
            <slot name="header"></slot>
            <h1>这里是带有slot的组件</h1>
            <slot name="footer"></slot>
        </div>
    </template>
    <script>
        var vm=new Vue({
            el:"#box",
            data:{},
            components:{
                myslot:{
                    template:"#myslot",
                }
            }
        })
    </script>
</body>
</html>